

CIRCUIT DESIGN METHOD, APPARATUS, AND PROGRAM

## BACKGROUND OF THE INVENTION

## 5 1. Field of the Invention

The present invention relates to a method, apparatus, and program for designing a processing circuit for performing processing such as a linear transform as used in for example error correction coding and decoding.

## 10 2. Description of the Related Art

For example, in error correction coding and decoding of the Hamming code etc., various types linear transform processings are performed in a linear space defined on a finite field.

15 In such linear transform processing, for example, a predetermined base on the linear space is used to express a dimension on the linear space by a vector and linear transform processing is applied to this vector to obtain a new vector.

20 In the above-mentioned error correction coding and decoding, for example, sometimes a plurality of bits of predetermined data are subjected to a plurality of processings for different linear transforms.

25 Conventionally, for example, a processing circuit is designed to perform this plurality of

processings independently.

Summarizing the problem to be solved by the invention, however, as explained above, if designing a processing circuit to perform the above plurality of 5 processings independently, the processing circuit becomes large in scale.

#### SUMMARY OF THE INVENTION

An object of the present invention is to provide a circuit design method, apparatus, and program able to 10 design a processing circuit to be small in scale when designing a processing circuit to perform a plurality of different processings on predetermined data.

According to a first aspect of the invention, there is provided a circuit design method executed by computer 15 for designing a processing circuit for applying a plurality of different first processings to predetermined data comprising a first step of identifying second processings performing the same processing on the same data in pluralities of second processings forming each of 20 the plurality of first processings and a second step of designing a processing circuit comprising a first processing circuit shared by the plurality of first processings and performing the second processings identified in the first step and a second processing 25 circuit for performing processings other than the second

processings identified in the first step in the pluralities of second processings forming each of the plurality of first processings.

That is, in the circuit design method of the first 5 aspect of the invention, first, in a first step, second processings performing the same processing on the same data are identified among pluralities of second processings forming each of a plurality of first processings.

10 Then, in a second step, the processing circuit comprising a first processing circuit shared by the plurality of first processings and performing the second processings identified in the first step and a second processing circuit for performing processings other than 15 the second processings identified in the first step among the pluralities of second processings forming each of the plurality of first processings is designed.

According to a second aspect of the invention, there 20 is provided a circuit design apparatus of a processing circuit for applying a plurality of different first processings to predetermined data comprising a first means for identifying second processings performing the same processing on the same data in pluralities of second processings forming each of the plurality of first 25 processings and a second means for designing a processing

circuit comprising a first processing circuit shared by the plurality of first processings and performing the second processings identified by the first means and a second processing circuit for performing processings  
5 other than the second processings identified by the first means in the pluralities of second processings forming each of the plurality of first processings.

In the circuit design apparatus of the second aspect of the invention, a first means identifies second processings performing the same processing on the same data among the pluralities of second processings forming each of the plurality of first processings.

A second means designs a processing circuit comprising a first processing circuit shared by the plurality of first processings and performing the second processings identified by the first means and a second processing circuit for performing processings other than the second processings identified by the first means among the pluralities of second processings forming each of the plurality of first processings.

According to a third aspect of the invention, there is provided a program executed in a circuit design apparatus of a processing circuit for applying a plurality of different first processings to predetermined data comprising a first routine of identifying second

processings performing the same processing on the same data in pluralities of second processings forming each of the plurality of first processings and a second routine of designing a processing circuit comprising a first 5 processing circuit shared by the plurality of first processings and performing the second processings identified in the first routine and a second processing circuit for performing processings other than the second processings identified in the first routine in the 10 pluralities of second processings forming each of the plurality of first processings.

#### BRIEF DESCRIPTION OF THE DRAWINGS

The above object and features of the present invention will be more apparent from the following 15 description of the preferred embodiments given with reference to the accompanying drawings, wherein:

FIG. 1 is a view for explaining the related art of the present invention;

FIG. 2 is a view for explaining the related art of 20 the present invention;

FIG. 3 is a diagram for explaining the related art of the present invention;

FIG. 4 is a view for explaining the related art of the present invention;

25 FIG. 5 is a view for explaining the related art of

the present invention;

FIG. 6 is a view for explaining peripheral circuits of a processing circuit designed by a circuit design method of a first embodiment of the present invention;

5 FIG. 7 is a view for explaining a computer for executing the circuit design method of the first embodiment of the present invention;

10 FIG. 8 is a flow chart for explaining a case of designing a processing circuit by the procedure of the circuit design method of the first embodiment of the 15 present invention;

FIG. 9 is a view for explaining a processing circuit designed by the circuit design method of the first embodiment of the present invention;

15 FIG. 10 is a view for explaining a data output timing of the processing circuit shown in FIG. 9;

FIG. 11 is a view for explaining a concrete example of the processing circuit shown in FIG. 9;

20 FIG. 12 is a view for explaining a processing circuit for performing  $\gamma^r$  to  $\gamma^{kr}$ -times multiprocessings ( $x\gamma^r$ ) defined by the circuit design method of the first embodiment of the present invention;

25 FIG. 13 is a view for explaining the related art of a circuit design method of a second embodiment of the present invention; and

FIG. 14 is a view for explaining the circuit design method of the second embodiment of the present invention.

#### DESCRIPTION OF THE PREFERRED EMBODIMENTS

Before giving an explanation of embodiments of the 5 present invention, a more detailed explanation will be given of the related art for reference purposes.

##### [Related Art of Invention]

FIG. 1 is a view of the configuration of a processing circuit 101 according to a related art of the 10 present invention.

The processing circuit 101 receives as input the data "a" and outputs the data  $b_1$  to  $b_k$ .

The processing circuit 101 has a plurality of systems of processing circuit modules for sequentially 15 performing processings  $C_{i,1}$  to  $C_{i,l_i}$  defined by matrixes  $M_{i,1}$  to  $M_{i,l_i}$  in the systems, where "i" is a natural number of 2 or more satisfying  $1 \leq i \leq k$ , and  $l_i$  is a natural number. These processing circuit modules perform processings in parallel.

20 The processing modules are configured by directly connecting a plurality of processing circuits  $2i1_j$  for performing processings  $C_{i,1}$  to  $C_{i,l_i}$ .

The processing circuit 101 receives as input the data "a" expressed by a vector by a base on the linear 25 space, applies linear processing to the data "a" in the

processing circuits  $21l_1$  to  $2kl_k$ , and outputs  $b_1$  to  $b_k$  from the processing circuits  $21l_1$  to  $2kl_k$ .

The processing circuit 1 shown in FIG. 1 can achieve a reduction of size and increase of speed by 5 designing it like the processing circuit 201 using the processing circuit modules  $il_j$  ( $j$  is integer of 2 or more) combining the processings  $C_{1,1}$  to  $C_{1,11}$  in the processing circuit modules as shown in FIG. 2.

In this case, linear transform strings defined as 10 shown in FIG. 2 and the following (1-1) are combined as shown in the following (1-2):

$\{C_{1,1}, C_{1,2}, \dots, C_{1,11}\},$   
 $\{C_{2,1}, C_{2,2}, \dots, C_{2,12}\},$   
...  
15  $\{C_{k,1}, C_{k,2}, \dots, C_{k,1k}\},$   
 $\{\text{Range of } C_{1,j-1}\} \subset \{\text{Domain of } C_{1,j}\}$

(1-1)

$C_{1,11} \circ \dots \circ C_{1,2} \circ C_{1,1}: a \mapsto b_1$   
 $C_{2,12} \circ \dots \circ C_{2,2} \circ C_{2,1}: a \mapsto b_2$   
20 ...  
25  $C_{k,1k} \circ \dots \circ C_{k,2} \circ C_{k,1}: a \mapsto b_k$  (1-2)

In this specification " $X \mapsto Y$ " means " $Y$ " is obtains by performing a corresponding operation with respect to 25 " $X$ ".

At this time, when making the processings  $C_{i,1}$  to  $C_{i,11}$  shown in the above (1-1) the matrix  $M_{i,1}$  to  $M_{i,11}$  for linear transforms, the above (1-1) and (1-2) are indicated as in the following (1-3) and (1-4):

$$\begin{aligned}
 & \{M_{1,1}, M_{1,2}, \dots, M_{1,11}\}, \\
 & \{M_{2,1}, M_{2,2}, \dots, M_{2,12}\}, \\
 & \dots \quad \dots \quad \dots \quad \dots \\
 & \{M_{k,1}, M_{k,2}, \dots, M_{k,1k}\}
 \end{aligned} \tag{1-3}$$

$$\begin{aligned}
 M_1 &:= M_{1,1} \dots M_{1,2} M_{1,1} : a \mapsto b_1 \\
 M_2 &:= M_{2,1} \dots M_{2,2} M_{2,1} : a \mapsto b_2 \\
 &\dots \\
 M_k &:= M_{k,1} \dots M_{k,2} M_{k,1} : a \mapsto b_k
 \end{aligned} \tag{1-4}$$

By this, the processing circuit 201 can be designed as a circuit for the matrix shown in the following (1-5):

$$M := \begin{pmatrix} M_1 \\ M_2 \\ \dots \\ M_k \end{pmatrix} : a \mapsto \begin{pmatrix} b_1 \\ b_2 \\ \dots \\ b_k \end{pmatrix} \quad (1-5)$$

20 Next, an explanation will be given of the design  
method for a processing circuit for performing a  
plurality of processes comprising applying first linear  
transforms  $D$  different predetermined numbers of times to

the input data FS0 and outputting data  $b_1$  to  $b_k$  as the results of the related processings.

FIG. 3 is a view for explaining such a processing circuit 301 and the peripheral circuits thereof.

5 As shown in FIG. 3, a selector 312 selects one data between the input data "a" and the data MLS on the basis of a selection signal SEL and outputs the related selected data FS0 to a register 313<sub>0</sub> and a processing circuit 301.

10 The processing circuit 301 performs a plurality of processings for applying first linear transforms D different predetermined numbers of times to the data FS0 input from the selector 312 and outputs the data  $b_1$  to  $b_k$  as the results of the processings to the registers 313<sub>1</sub> to 15 313<sub>k</sub>.

The registers 313<sub>1</sub> to 313<sub>k</sub> hold the input data FS0 and  $b_1$  to  $b_k$  and output them as data OUT<sub>1</sub> to OUT<sub>k</sub> at predetermined timings.

20 The processing circuit 314 receives as input the data OUT<sub>k</sub>, applies the first linear processing D to this, and outputs the data MSL as the result thereof to the selector 312.

25 The processing circuit 301 is designed, for example as shown in FIG. 3, by serially connecting a plurality of processing circuits 321<sub>1</sub> to 321<sub>k</sub> for performing linear

transforms D, inputting the data "a" to the first stage circuit 321<sub>1</sub>, and outputting the data b<sub>1</sub> to b<sub>k</sub> generated at individual processing circuits 321<sub>1</sub> to 321<sub>k</sub> to the registers 313<sub>1</sub> to 313<sub>k</sub>.

5       Here, the processing circuit 301 shown in FIG. 3 is designed as shown in FIG. 4 where it performs  $\alpha$ -times multiprocessings on the dimension of the finite field  $F(2^4)$ , i.e.,  $\alpha$ ,  $\alpha^2+\alpha+1 = 0$ .

10      In this case, as shown in FIG. 3, for the data "a" input at a certain timing, the data OUT<sub>0</sub>, OUT<sub>1</sub>, and OUT<sub>2</sub> become as follows:

OUT<sub>0</sub>: a,  $a*\alpha^{k+1}$ ,  $a*\alpha^{k+2}$ , ...,

OUT<sub>1</sub>:       $a*\alpha$ ,  $a*\alpha^{k+2}$ ,  $a*\alpha^{2k+3}$ , ...,

15      OUT<sub>2</sub>:       $a*\alpha^2$ ,  $a*\alpha^{k+3}$ ,  $a*\alpha^{2k+4}$ , ...,

Here, where  $FS0=A0+A1\alpha$ , these become as follows:

$FS0\alpha=A1+(A0+A1)\alpha$

$FS0\alpha^2=(A0+A1)+A0\alpha$

20      Accordingly, the processing circuits 321<sub>1</sub> and 321<sub>2</sub> shown in FIG. 4 are individually designed by the adder circuits 351<sub>1</sub> and 351<sub>2</sub> as shown in FIG. 5.

25      As mentioned above, however, there is a problem in that the circuit scale becomes large when designing the processing circuit 301.

Further, in the processing circuit 301, there is a problem in that the time from when the data "a" is input to the first stage circuit 321<sub>1</sub> to when the data b<sub>k</sub> is output from the final stage circuit 321<sub>k</sub> becomes long, so 5 a high performance processing circuit 301 cannot be designed.

Below, an explanation will be given of an embodiment of the present invention for solving the problems of the related art mentioned above.

10 [First Embodiment]

FIG. 6 is a view for explaining peripheral circuits of a processing circuit 11 designed by the circuit design method of the present embodiment.

As shown in FIG. 6, a selector 12 selects one data 15 between the input data "a" and the data MLS on the basis of a selection signal SEL and outputs the selected data FSO to a register 13<sub>0</sub> and the processing circuit 11.

The processing circuit 11 performs a plurality of processings for applying first linear transforms D 20 different predetermined numbers of times to the data FSO input from the selector 12 and outputs the data b<sub>1</sub> to b<sub>k</sub> as the results of the processings to the registers 13<sub>1</sub> to 13<sub>k</sub>.

The registers 13<sub>1</sub> to 13<sub>k</sub> hold the input data FSO and 25 b<sub>1</sub> to b<sub>k</sub> and output them as data OUT<sub>1</sub> to OUT<sub>k</sub> at

predetermined timings.

The processing circuit 14 receives as input the data OUT<sub>k</sub>, applies the first linear processing D to this, and outputs the data MSL as the result thereof to the 5 selector 12.

The circuit design method of the present embodiment designs the processing circuit 11 shown in FIG. 6.

In the present embodiment, when the predetermined linear space is an m-th enlargement of a finite field F<sub>q</sub>, 10 where "q" is the prime number and the dimension thereof is expressed by the m-th dimension vector on F<sub>q</sub>, the predetermined linear space is indicated by the following (2-1) or F(q<sup>m</sup>):

15 Linear space F<sub>q</sub><sup>m</sup> (2-1)

Further, using the base shown in the following (2-2) as the predetermined base, the data "a" of the predetermined data is indicated as in the following (2-3) 20 on a basis of the base shown in the following (2-2):

{γ<sub>1</sub>, γ<sub>2</sub>, ..., γ<sub>m</sub>} (2-2)

a=a<sub>1</sub>γ<sub>1</sub>+a<sub>2</sub>γ<sub>2</sub>+... a<sub>m</sub>γ<sub>m</sub> (2-3)

25 Further, using the data "a" as the m-th dimension

vector, the result becomes as in the following (2-4):

$$a = \begin{pmatrix} a_1 \\ a_2 \\ \vdots \\ \vdots \\ a_m \end{pmatrix} \quad (2-4)$$

Further, the first linear transform D is defined as

5 the linear transform D on the linear space shown in the  
above (2-1).

Further, the data "b" of the result of the above  
plurality of processings is shown as the k-th dimension  
vector by the following (2-5) and the data  $b_i$  indicating  
10 the results of the processings forming the data "b" shown  
in the following (2-5) is shown as the  $d_i$ -th dimension  
vector by the following (2-6):

Here, "m" and  $d_i$  are integers of 2 or more, the  
predetermined number of times corresponding to at least  
15 one of the above plurality of processings is 2 or more,  
and "k" is an integer of 2 or more.

$$b = \begin{pmatrix} b_1 \\ b_2 \\ \vdots \\ \vdots \\ b_k \end{pmatrix} \quad (2-5)$$

$$b_i = \begin{pmatrix} b_{i,1} \\ b_{i,2} \\ \vdots \\ \vdots \\ b_{i,d_i} \end{pmatrix} \quad (2-6)$$

Here, when making the above plurality of processings  $OP_1$  to  $OP_k$ , they are indicated by the following (3-7):

5

$$\begin{aligned}
 OP_1: \{D\}, & \quad D: & a \mapsto b_1 \\
 OP_2: \{D, D\}, & \quad D^2 := D \circ D: & a \mapsto b_2 \\
 OP_3: \{D, D, D\}, & \quad D^3 := D \circ D \circ D: & a \mapsto b_3 \\
 & \dots \dots \dots \dots \dots \dots \\
 10 \quad OP_k: \{D, D, D, \dots, D\}, & \quad D^k := D \circ D \circ D \circ \dots \circ D: & a \mapsto b_k \quad (2-7)
 \end{aligned}$$

Then, when making the matrix comprised by "di" rows and "m" columns expressing the first linear transform  $D$   $M_d$ , the above (2-7) is indicated by the following (2-8):

15

$$\begin{aligned}
 \{M_d\}, & \quad M_d: a \mapsto b_1 & (2-8) \\
 \{M_d, M_d\}, & \quad M_d^2: a \mapsto b_2 \\
 \{M_d, M_d, M_d\}, & \quad M_d^3: a \mapsto b_3 \\
 & \dots \dots \dots \\
 20 \quad \{M_d, M_d, M_d, \dots, M_d\}, & \quad M_d^k: a \mapsto b_k
 \end{aligned}$$

A matrix  $M$  of  $k \times m$  obtained by vertically

arranging the matrixes  $M_d$  to  $M_d^k$  comprised of "di" rows and "m" columns expressing the combination of the transform strings defined by the above  $OP_1$  to  $OP_k$  is shown by the following (2-9) :

5

$$M := \begin{pmatrix} M_d \\ M_d^2 \\ \dots \\ M_d^k \end{pmatrix} : a \mapsto \begin{pmatrix} b_1 \\ b_2 \\ \dots \\ b_k \end{pmatrix} = \begin{pmatrix} D \cdot a \\ D^2 \cdot a \\ \dots \\ D^k \cdot a \end{pmatrix} \quad (2-9)$$

As shown in the above (2-9), the matrix M defines "k: number of processings for the first linear transform 10 and the second transforms  $D^2$  to  $D^k$  on the data "a".

FIG. 7 is a view for explaining the computer 29 for executing the circuit design method of the present embodiment.

As shown in FIG. 7, the computer 29 has for example 15 an operating unit 31, a display 32, a memory 33, and a CPU 34 all connected via a bus 30.

The operating unit 31 is an operating means such as a keyboard or a mouse and is used for instructing execution of the program, instructing selection of data, 20 and inputting data at the CPU 34.

The display 32 displays the processing results of the CPU 34.

The memory 33 stores a program 41 to be executed by

the CPU 34 and data 42 used for the execution of the program 41.

The CPU 34 executes the program 41 to perform the following processings and uses the data 42 in the process 5 of execution of the program 41 for processing for designing the circuit of the processing circuit 11.

The program 41 corresponds to the program of the present invention and describes routines indicating the contents of the following steps.

10 Further, the circuit design apparatus of the present invention is configured by the CPU 34 executing the program 41. The CPU 34 executes step ST12 to design the first means of the present invention, and the CPU 34 executes step ST13 to design the second means of the 15 present invention.

Below, an explanation will be given of an example of the operation of the circuit design method of the present embodiment in relation to the processing of the CPU 34.

FIG. 8 is a flow chart for explaining an example of 20 the operation of the circuit design method of the present embodiment.

#### Step ST11

The CPU 34 receives as input the data for defining the formats of the input and the output of the processing 25 performed by the processing circuit 11 as shown in the

above (2-4), (2-5), and (2-6) and the contents of a plurality of processings for applying a number of first linear transforms D corresponding to the predetermined number of times of processing by the processing circuit 5 11 to the data "a" as shown in the above (2-7) in accordance with an operation by the user on the operating unit 31.

**Step ST12**

The CPU 34 performs the processing for generating 10 the matrix M indicated in the above (2-9) for performing the second linear transform (first processing) obtained by combining a number of the first linear transforms D corresponding to the above predetermined number of times for each of the plurality of processings performed by the 15 processing circuit 11 shown in the above (2-7) input at step ST11.

**Step ST13**

The CPU 34 identifies the second processings performing the same processing on the same data among the 20 pluralities of second processings forming each of the plurality of second linear transforms (first processings) defined at the above step ST12.

**Step ST14**

The CPU 34 designs a processing circuit 11 shown in 25 FIG. 9 comprised of a first processing circuit shared by

the plurality of second linear transforms (first processings) and performing the second processings identified at step ST13 and a second processing circuit for performing the processings other than the above 5 second processings identified at step ST13 among the above pluralities of second processings forming each of the above plurality of first processings.

At this time, the CPU 34 generates the design data of the processing circuit 11 so as to perform "k" number 10 of processings for performing the first linear transforms  $D$  to  $D^k$  on the data  $FS_0$  in parallel on the basis of the matrix  $M$  generated at step ST12 shown in the above (2-9).

Concretely, the CPU 34 generates the design data indicating the design of the processing circuit 11 15 comprised of the processing circuits  $21_1$  to  $21_k$  for performing the first linear transforms  $D$  to  $D^k$  on the data  $FS_0$  arranged in parallel as shown in FIG. 9.

By this, the CPU 34 generates the design data of the processing circuit 11 designed so as to apply the linear 20 transforms defined by the matrix  $M$  indicated by above (2-9) to the input data  $FS_0$  and to output the data  $b_1$  to  $b_k$ .

By designing the processing circuit 11 as shown in FIG. 9, the outputs from the registers  $13_0$  to  $13_k$  become 25 as shown in FIG. 10 plotting the time in the lateral direction.

Namely, the data  $b_1$  to  $b_k$  are output from the processing circuit 1 at approximately the same timing, so the data  $OUT_0$  to  $OUT_k$  are also output at approximately the same timing.

5 At this time, the relationships among the processing of the matrix  $M$  performed by the processing circuit 11, the data  $FSO$  input to the processing circuit 11, and the data  $OUT_0$  to  $OUT_k$  are indicated by the following (2-10) :

$$M \cdot FSO = \begin{pmatrix} D \cdot FSO \\ D^2 \cdot FSO \\ D^3 \cdot FSO \\ \vdots \\ D^k \cdot FSO \end{pmatrix} = \begin{pmatrix} OUT_0 \\ OUT_1 \\ OUT_2 \\ \vdots \\ OUT_k \end{pmatrix} \quad (2-10)$$

10 Here, the matrix  $M$  is comprised by the dimension of the linear space defined by the above (2-1), so the data  $OUT_1$  to  $OUT_k$  (data  $b_1$  to  $b_k$ ) are defined as the product of the dimension of the linear space and elements of the data  $FSO$  and the sum of the same. For this reason, the 15 combinations become finite at most. For example, when the value "k" is large with respect to the value "m", as shown in FIG. 8, by feeding back the data  $b_k$  output from the processing circuit 11 via the processing circuit 14 and the selector 12 to the processing circuit 11, a processing circuit 11 able to cope with a variety of 20 processings can be constructed with a small scale design.

Below, when the processing circuits  $21_1$  and  $21_k$  of the processing circuit 11 shown in FIG. 9 perform  $\alpha$ -times multiprocessing with respect to the dimensions of the finite field  $F(2^4)$ , i.e.,  $\alpha$ ,  $\alpha^2+\alpha+1=0$ , they are designed 5 like the processing circuit 221 shown in FIG. 11.

In this case, as shown in FIG. 3, for the data "a" input at a certain timing, the data  $OUT_0$ ,  $OUT_1$ , and  $OUT_2$  become as follows:

10         $OUT_0: a, a*\alpha^{k+1}, a*\alpha^{2k+2}, \dots,$   
           $OUT_1: a*\alpha, a*\alpha^{k+2}, a*\alpha^{2k+3}, \dots,$   
           $OUT_2: a*\alpha^2, a*\alpha^{k+3}, a*\alpha^{2k+4}, \dots,$

15        Namely, when  $FS0=A0+A1\alpha$ , the data  $OUT_0$ ,  $OUT_1$ , and  $OUT_2$  in the next clock cycle become as follows:

20         $OUT_0: FS0=A0+A1\alpha$   
           $OUT_1: FS0*\alpha=A1+(A0+A1)\alpha$   
           $OUT_2: FS0*\alpha*\alpha=(A0+A1)+A0\alpha$

25        In this case, at step ST13 shown in FIG. 8 mentioned above, the CPU 34 identifies the second processings performing the same processing on the same data among the plurality of second processings forming the above  $\alpha$ -times multiprocessings, that is, the processing "A0+A1".

Then, at step ST14 shown in FIG. 8, the CPU 34 designs a processing circuit 11a shown in FIG. 11 comprising a first processing circuit 115 shown in FIG. 11 (adder circuit in FIG. 11) shared by a plurality of  $\alpha$ -times multiprocessings (that is,  $\alpha$ -times multiprocessing and  $\alpha^2$ -times multiprocessing) and performing the processing "A0+A1" identified at step ST13 and a second processing circuit shown in FIG. 11 (none in the example shown in FIG. 11) for performing the processings other than the above second processings identified at step ST13 among the above pluralities of second processings forming each of the plurality of  $\alpha$ -times multiprocessings.

Note that, in the above embodiment, when the above first linear transform is for performing the  $\gamma^r$ -times multiprocessings  $(x\gamma^r)$  with respect to the dimension  $\gamma$  of the linear space identified in the above (2-1), if the plurality of processings are  $OP_1$  to  $OP_k$ , they are indicated by the following (2-11):

20       $OP_1: \{(x\gamma^r)\}, \quad (x\gamma^r): \quad a \mapsto b_1$   
           $OP_2: \{(x\gamma^r), (x\gamma^r)\}, \quad (x\gamma^r) \circ (x\gamma^r): \quad a \mapsto b_2$   
           $OP_3: \{(x\gamma^r), (x\gamma^r), (x\gamma^r)\}, \quad (x\gamma^r) \circ (x\gamma^r) \circ (x\gamma^r): \quad a \mapsto b_3$   
          ...    ...    ...    ...    ...    ...    ...  
           $OP_k: \{(x\gamma^r), (x\gamma^r), (x\gamma^r), \dots, (x\gamma^r)\}$   
25       $(x\gamma^r) \circ (x\gamma^r) \circ (x\gamma^r) \circ \dots \circ (x\gamma^r) \circ : a \mapsto b_k$

Then, when making the matrix comprised by  $d_i$  rows and " $m$ " columns expressing the first linear transform  $D_{Mr}$ , the above (2-11) is indicated by the following (2-12) :

$$\begin{array}{lll} \{M_r\}, & M_r: a \mapsto b_1 & (2-12) \\ \{M_r, M_r\}, & M_r^2: a \mapsto b_2 \\ \{M_r, M_r, M_r\}, & M_r^3: a \mapsto b_3 \\ 10 \quad \dots \dots \dots \dots & \dots \\ \{M_r, M_r, M_r, \dots, M_r\}, & M_r^k: a \mapsto b_k \end{array}$$

The matrix  $Mr$  of  $k \times m$  obtained by vertically arranging matrixes  $M_r$  to  $M_r^k$  comprised by  $d_i$  rows and " $m$ " columns expressing the combination of the transform strings defined by above  $OP_1$  to  $OP_k$  is indicated by the following (2-13) :

Here,  $Mr^x$  ( $x$  is an integer satisfying  $1 \leq x \leq k$ ) is the matrix obtained by combining  $X$  number of  $M_r$ s.

$$M := \begin{pmatrix} M_r \\ M_r^2 \\ \dots \\ M_r^k \end{pmatrix} : a \mapsto \begin{pmatrix} b_1 \\ b_2 \\ \dots \\ b_k \end{pmatrix} = \begin{pmatrix} \gamma^r \cdot a \\ \gamma^{2r} \cdot a \\ \dots \\ \gamma^{kr} \cdot a \end{pmatrix} \quad (2-13)$$

20

As shown in above (2-13), the matrix  $M$  defines " $k$ " number of processings each performing  $\gamma^r$  to  $\gamma^{kr}$ -times multiprocessings ( $\gamma^r$ ) on the data  $a$ .

In this case, as shown in FIG. 12, the CPU 34 generates design data indicating the design of a processing circuit 11 having the processing circuits 21<sub>1</sub> to 21<sub>k</sub> each performing  $\gamma^x$  to  $\gamma^{xr}$ -times multiprocessings 5 ( $*\gamma^x$ ) on the data FSO.

As explained above, in the circuit design method of the present embodiment, at step ST13 shown in FIG. 8, second processings performing the same processing on the same data among the pluralities of second processings 10 forming each of the plurality of first processings (D-times multiprocessings and  $\alpha$ -times multiprocessings) are identified.

Then, at step ST14, the processing circuits 11 and 11a comprising a first processing circuit shared by the 15 plurality of first processings and performing the identified second processings and a second processing circuit for performing the processings other than the identified second processings among the pluralities of second processings forming each of the plurality of first 20 processings are designed.

For this reason, according to the circuit design method of the present embodiment, the processing circuits 11 and 11a can be designed to be small in scale.

Further, in the circuit design method of the present 25 embodiment, at step ST12 shown in FIG. 8, for each of the

plurality of processings performed by the processing circuit 11 indicated in the above (2-7) input at step ST11, a matrix M indicated in the above (2-9) for performing the second linear transforms (first processings) obtained by combining the number of first linear transforms D corresponding to the predetermined number of times is generated. The processings of steps ST13 and ST14 mentioned above are carried out with respect to this.

For this reason, according to the circuit design method of the present embodiment, the processing circuits 11 and 11a can be designed to be small in scale and, at the same time, the processing time can be shortened.

Further, in the circuit design method of the present embodiment, as shown in FIG. 9 and FIG. 11, the processing circuit 11 performs the first processings in parallel on the data FS0, so the processing time can be further shortened.

Namely, the processing circuits 21<sub>1</sub> to 21<sub>k</sub> process the data FS0 (data "a") in parallel, so all of the data b<sub>1</sub> to b<sub>k</sub> (data OUT<sub>1</sub> to OUT<sub>k</sub>) can be obtained at approximately the same timing.

For this reason, a processing circuit 11 shortening the time from when the data FS0 is input to when the data b<sub>2</sub> to b<sub>k</sub> are obtained over the design shown in FIG. 3 can

be designed.

[Second Embodiment]

In the present embodiment, the case where 4 bits of data D (= D[3], D[2], D[1], D[0]) treated as dimensions 5 on the finite field  $F(2^4)$  are regarded as vertical vectors, and a circuit for applying two linear transforms indicated by the matrixes M1 and M2 shown in the following (2-14) and (2-15) with respect to the related data D is designed will be exemplified.

10

$$M1 = \begin{pmatrix} 1 & 1 & 0 & 1 \\ 1 & 0 & 1 & 0 \\ 0 & 0 & 0 & 1 \\ 0 & 1 & 1 & 0 \end{pmatrix} \quad (2-14)$$

$$M2 = \begin{pmatrix} 0 & 1 & 0 & 1 \\ 1 & 0 & 1 & 1 \\ 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \end{pmatrix} \quad (2-15)$$

15

Conventionally, the output values  $E1=M1 \cdot D$  and  $E2=M2 \cdot D$  are expressed as vertical vectors and indicated by the following (2-16) and (2-17):

$$\begin{aligned} E1 &= (E1[3], E1[2], E1[1], E1[0]) \\ &= (D[1]+D[2], D[3], D[0]+D[2], D[0]+D[1]+D[3]) \end{aligned} \quad (2-16)$$

20

$$\begin{aligned} E2 &= (E2[3], E2[2], E2[1], E2[0]) \\ &= (D[1], D[0], D[0]+D[2]+D[3], D[1]+D[2]) \end{aligned} \quad (2-17)$$

In the conventional circuit design method, as shown in FIG. 13, a processing circuit 401 comprising a processing circuit 402 for performing the processing shown in the above (2-16) and a processing circuit 403 for performing the processing shown in the above (2-17) 5 is designed.

The processing circuit 402 is comprised of adder circuits 411, 412, 413, and 414.

Further, the processing circuit 403 is comprised of 10 adder circuits 421, 422, and 423.

The circuit design method of the present embodiment is the same in that it applies the linear transforms expressed by the matrixes M1 and M2 shown in the above (2-14) and (2-15) to 4 bits of data D (= D[3], D[2], D[1], 15 D[0]) handled as dimensions on the finite field  $F(2^4)$ .

In the present embodiment, in place of using two 4 x 4 matrixes, use is made of the matrix M shown in the following (2-18) connecting the matrixes M1 and M2:

$$M = \begin{pmatrix} M1 \\ M2 \end{pmatrix} = \begin{pmatrix} 1 & 1 & 0 & 1 \\ 1 & 0 & 1 & 0 \\ 0 & 0 & 0 & 1 \\ 0 & 1 & 1 & 0 \\ 0 & 1 & 1 & 0 \\ 1 & 0 & 1 & 1 \\ 1 & 0 & 0 & 0 \\ 0 & 1 & 0 & 0 \end{pmatrix} \quad (2-18)$$

20 In the circuit design method of the present embodiment, the processing of the above matrix M is

carried out and, in the processings among the above (2-16) and (2-17), "D[0]+D[2]" and "D[1]+D[2]", which are common second processings, are identified among the plurality of second processings forming the first 5 processing corresponding to the matrix M1 and the first processing corresponding to the matrix M2.

Then, as shown in FIG. 14, the adder circuits 412 and 421 shown in FIG. 13 for performing the second processing "D[0]+D[2]" and the adder circuits 413 and 422 10 shown in FIG. 13 for performing the second processing "D[1]+D[2]" are shared, so the adder circuits 412 and 413 are deleted. Therefore, a processing circuit 401 having a circuit scale reduced in comparison with the processing circuit 401 shown in FIG. 13 is designed.

15 By this, a processing circuit 403 shown in FIG. 14 for performing the same processing as the processing circuit 401 shown in FIG. 13 can be designed in a smaller scale in comparison with the processing circuit 401.

The present invention is not limited to the above 20 embodiments.

As another embodiment, it is also possible to use a base shown in the following (2-19) as the above predetermined base, show the above data "a" as in the following (2-20), and show the data "a" as in the 25 following (2-21) as the m-th dimension vector:

$$\{1, \gamma, \gamma^2, \dots, \gamma^{m-1}\} \quad (2-19)$$

$$a = a_0 + a_1\gamma + a_2\gamma^2 + a_3\gamma^3 + \dots + a_{m-1}\gamma^{m-1} \quad (2-20)$$

$$a = \begin{pmatrix} a_0 \\ a_1 \\ a_2 \\ \vdots \\ a_{m-1} \end{pmatrix} \quad (2-21)$$

5        Summarizing the effects of the invention, as  
explained above, according to the present invention, it  
is possible to provide a circuit design method, apparatus,  
and program able to design a processing circuit to be  
small in scale when designing a processing circuit for  
10      performing a plurality of different processings on  
predetermined data.

While the invention has been described with  
reference to specific embodiments chosen for purpose of  
illustration, it should be apparent that numerous  
15      modifications could be made thereto by those skilled in  
the art without departing from the basic concept and  
scope of the invention.